<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script type="text/javascript" src="../js/vue.js"></script>
    <script type="text/javascript" src="../js/dayjs.min.js"></script>

</head>
<!--
			过滤器：
				定义：对要显示的数据进行特定格式化后再显示（适用于一些简单逻辑的处理）。
				语法：
						1.注册过滤器：Vue.filter(name,callback) 或 new Vue{filters:{}}
						2.使用过滤器：{{ xxx | 过滤器名}}  或  v-bind:属性 = "xxx | 过滤器名"
				备注：
						1.过滤器也可以接收额外参数、多个过滤器也可以串联
						2.并没有改变原本的数据, 是产生新的对应的数据
		-->
<body>
<!-- 准备好一个容器-->
<div id="root">
    <h2>显示格式化后的时间</h2>
    <!-- 计算属性实现 -->
    <h3>现在是：{{fmtTime}}</h3>
    <!-- methods实现 -->
    <h3>现在是：{{getFmtTime()}}</h3>
    <!-- 过滤器实现 -->
    <h3>现在是：{{currDateTime | timeFormatter}}</h3>
    <h3>现在是：{{currDateTime | fmtTime}}</h3>
    <!-- 过滤器实现（传参） -->
    <h3>现在是：{{currDateTime | timeFormatter('YYYY-MM-DD')}}</h3>
    <!-- 多个过滤器串联实现（传参） -->
    <h3>现在是：{{currDateTime | timeFormatter('YYYY-MM-DD') | mySlice}}</h3>
    <h3 :x="msg | mySlice">尚硅谷</h3>
</div>


<div id="root2">
    <h2>{{msg | mySlice}}</h2>
</div>
<script>

    //全局过滤器
    Vue.filter('mySlice',function (value) {
        return value.slice(0,4)
    })

    Vue.filter('fmtTime',function (value,str) {
        return dayjs(value).format(str)
    })
    const vm = new Vue({

        el: '#root',
        data: {
            currDateTime: Date.now(),
            msg: "你好，再见啊"
        },
        computed: {

            fmtTime() {
                return dayjs(this.currDateTime).format('YYYY年MM月DD日 HH:mm:ss')
            }
        },

        methods: {
            getFmtTime() {
                return dayjs(this.currDateTime).format('YYYY年MM月DD日 HH:mm:ss')
            }
        },

        //局部过滤器
        filters: {

            timeFormatter(value,str='YYYY年MM月DD日 HH:mm:ss') {
                console.log('v=',value)
                return dayjs(value).format(str)
            },
            /*
            mySlice(str) {
                return str.slice(0,4)

            }*/
        }
    })

    new Vue({
        el:'#root2',
        data:{
            msg:'hello,atguigu!'
        }
    })
</script>
</body>
</html>